//给你一个数组 nums，对于其中每个元素 nums[i]，请你统计数组中比它小的所有数字的数目。
//
// 换而言之，对于每个 nums[i] 你必须计算出有效的 j 的数量，其中 j 满足 j != i 且 nums[j] < nums[i] 。
//
// 以数组形式返回答案。
//
//
//
// 示例 1：
//
// 输入：nums = [8,1,2,2,3]
//输出：[4,0,1,1,3]
//解释：
//对于 nums[0]=8 存在四个比它小的数字：（1，2，2 和 3）。
//对于 nums[1]=1 不存在比它小的数字。
//对于 nums[2]=2 存在一个比它小的数字：（1）。
//对于 nums[3]=2 存在一个比它小的数字：（1）。
//对于 nums[4]=3 存在三个比它小的数字：（1，2 和 2）。
//
//
// 示例 2：
//
// 输入：nums = [6,5,4,8]
//输出：[2,1,0,3]
//
//
// 示例 3：
//
// 输入：nums = [7,7,7,7]
//输出：[0,0,0,0]
//
//
//
//
// 提示：
//
//
// 2 <= nums.length <= 500
// 0 <= nums[i] <= 100
//
//
// Related Topics 数组与矩阵 哈希表 计数 排序 👍 252 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
function smallerNumbersThanCurrent(nums: number[]): number[] {


    const length: number = nums.length;
    const sortedArr: number[] = [...nums];
    sortedArr.sort((a, b) => a - b);
    const hashMap: Map<number, number> = new Map();
    for (let i = length - 1; i >= 0; i--) {
        // 从后往前，可以去掉前面的相同数算上后面的数的情况
        hashMap.set(sortedArr[i], i);
    }
    const resArr: number[] = [];
    for (let i = 0; i < length; i++) {
        resArr[i] = hashMap.get(nums[i]);
    }
    return resArr;
};
//leetcode submit region end(Prohibit modification and deletion)
